package com.zhong.system.domain;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.gitee.sunchenbin.mybatis.actable.annotation.Column;
import com.gitee.sunchenbin.mybatis.actable.annotation.IgnoreUpdate;
import com.gitee.sunchenbin.mybatis.actable.annotation.IsKey;
import com.gitee.sunchenbin.mybatis.actable.annotation.Table;
import com.gitee.sunchenbin.mybatis.actable.constants.MySqlTypeConstant;
import com.zhong.common.annotation.Excel;
import com.zhong.common.annotation.QueryField;
import com.zhong.common.core.enums.QueryCondition;
import lombok.Data;

import java.util.Date;

/**
 * 系统访问记录表 sys_logininfor
 *
 * @author zhongzc
 */
@Data
@TableName("sys_logininfor")
@Table(comment = "系统访问记录表", name = "sys_logininfor", isSimple = true)
public class SysLogininfor
{
    private static final long serialVersionUID = 1L;

    /** 用户ID */
    @IsKey
    @TableId(type = IdType.ASSIGN_UUID)
    @Column(length = 56)
    private String id;

    /** 用户账号 */
    @Excel(name = "用户账号")
    @QueryField(condition = QueryCondition.like)
    @Column(comment = "用户账号")
    private String userName;

    /** 登录状态 0成功 1失败 */
    @Excel(name = "登录状态 0成功 1失败 ", readConverterExp = "0=成功,1=失败")
    @Column(comment = "登录状态 0成功 1失败",type = MySqlTypeConstant.CHAR)
    private String status;

    /** 登录IP地址 */
    @Excel(name = "登录地址")
    @QueryField(condition = QueryCondition.like)
    @Column(comment = "登录IP地址")
    private String ipaddr;

    /** 登录地点 */
    @Excel(name = "登录地点")
    @Column(comment = "登录地点")
    private String loginLocation;

    /** 浏览器类型 */
    @Excel(name = "浏览器")
    @Column(comment = "浏览器类型")
    private String browser;

    /** 操作系统 */
    @Excel(name = "操作系统")
    @Column(comment = "操作系统")
    private String os;

    /** 提示消息 */
    @Excel(name = "提示消息")
    @Column(comment = "提示消息",type = MySqlTypeConstant.TEXT)
    private String msg;

    /** 访问时间 */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "访问时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    @Column(comment = "访问时间",type = MySqlTypeConstant.DATETIME)
    private Date loginTime;

    @IgnoreUpdate
    @TableField(exist = false)
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @QueryField(condition = QueryCondition.ge,fieldName = "loginTime")
    private Date beginLoginTime;

    @IgnoreUpdate
    @TableField(exist = false)
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @QueryField(condition = QueryCondition.le,fieldName = "loginTime")
    private Date endLoginTime;

    @IgnoreUpdate
    @TableField(exist = false)
    private Page page;

    @JsonIgnore
    public Page getPage() {
        if (page == null) {
            page = new Page();
        }
        return page;
    }
}
